﻿// Copyright (c) 2022-Now 少林寺驻北固山办事处大神父王喇嘛
// 
// SimpleAdmin 基于 Apache License Version 2.0 协议发布，可用于商业项目，但必须遵守以下补充条款:
// 1.请不要删除和修改根目录下的LICENSE文件。
// 2.请不要删除和修改SimpleAdmin源码头部的版权声明。
// 3.分发源码时候，请注明软件出处 https://gitee.com/dotnetmoyu/SimpleAdmin
// 4.基于本软件的作品，只能使用 SimpleAdmin 作为后台服务，除外情况不可商用且不允许二次分发或开源。
// 5.请不得将本软件应用于危害国家安全、荣誉和利益的行为，不能以任何形式用于非法为目的的行为。
// 6.任何基于本软件而产生的一切法律纠纷和责任，均于我司无关。

namespace SimpleAdmin.System;

/// <summary>
/// 权限校验服务
/// </summary>
public interface IAuthService : ITransient
{
    /// <summary>
    /// 获取图形验证码
    /// </summary>
    /// <returns></returns>
    Task<PicValidCodeOutPut> GetCaptchaInfo();

    /// <summary>
    /// 获取登录用户信息
    /// </summary>
    /// <returns></returns>
    Task<LoginUserOutput> GetLoginUser();

    /// <summary>
    /// 获取手机短信验证码
    /// </summary>
    /// <param name="input">验证码参数</param>
    /// <param name="loginClientType">登录类型</param>
    /// <returns></returns>
    Task<string> GetPhoneValidCode(GetPhoneValidCodeInput input, LoginClientTypeEnum loginClientType);

    /// <summary>
    /// 登录
    /// </summary>
    /// <param name="input">登录参数</param>
    /// <param name="loginClientType">登录类型</param>
    /// <returns>Token信息</returns>
    Task<LoginOutPut> Login(LoginInput input, LoginClientTypeEnum loginClientType);

    /// <summary>
    /// 手机号登录
    /// </summary>
    /// <param name="input">登录参数</param>
    /// <param name="loginClientType">登录端类型</param>
    /// <returns>Token信息</returns>
    Task<LoginOutPut> LoginByPhone(LoginByPhoneInput input, LoginClientTypeEnum loginClientType);

    /// <summary>
    /// 退出登录
    /// </summary>
    /// <param name="token">token</param>
    /// <param name="loginClientType">登出类型</param>
    /// <returns></returns>
    Task LoginOut(string token, LoginClientTypeEnum loginClientType);
}
